Bask

Shanghai Based Android Engineer currently develop Payment systems at Ctrip

👨‍🔧‍

Flutter-Android开发者文档 -Activity和Fragment

By Bask on null

This post is over a year old. Some of the content may be out of date.

喜欢我的小伙伴,一定要关注我的微信公众号啊!!!谢谢啦 AllAboutCoding AllAboutCoding

此文章为翻译Flutter官网的Flutter for Android Developers - Activities and fragments有兴趣的小伙伴可以移步官网查看。

注意:在Flutter应用中,你永远不会希望Android重启Activity,特别是因为这样直接反对Android文档的建议。例如,如果支持分屏,你需要添加** screenLayout**,还可能需要密度(density)。

Flutter中的Activity和Fragment是什么?

在Android中,Activity代表着用户可以做的集中的事情。Fragment代表用户的一种行为或用户的一部分交互。Fragment是一种将你的代码模块化的方法,通过结合用户的在大屏上的复杂交互,帮助扩展应用的UI。在Flutter中,这两个概念都在Widget的保护伞之下。 就像Intent那节提到的一样,因为在Flutter中一切都是Widget,所以Widget就代表着屏幕(screens)。你可以使用Navigator在两个不同的Route之间跳转,Route代表了不同的页面或是屏幕,或者可能只是不同的状态或相同的数据渲染。

如何监听Android Activity 生命周期事件?

在Android中,你可以重写Activity的方法或者在Application*中注册ActivityLifecycleCallbacks来捕获Activity的生命周期。在Flutter中,你没有这些概念,但是你可以通过挂载WidgetsBinding观察监听didChangeAppLifecycleState()**方法的改变事件来达到监听生命周期事件的目的。 可观察的生命周期事件有:

  • inactive ——应用已在活跃状态,并且还没有收到用户操作。因为在Android上没有等价的映射,所以这个事件仅仅在iOS上有效。
  • paused——应用对用户已不可见,用户操作已无效,并且在后台运行。等价于Android的onPause()方法。
  • resume——应用已显示并且已经可以响应用户的操作。等价于Android的onPostResume ()方法。
  • suspending——应用暂时处于暂停状态。这等价于Android的onStop;因为在iOS上没有等价的方法,所以这个方法不会在iOS上触发。

关于这些状态的更多详细解释,请看生命周期状态文档 你可能注意到,只有一小部分Activity生命周期事件有效;而FlutterActivity确实捕获了Activity的所有生命周期事件并将它们发送给Flutter引擎,它们绝大多数都被屏蔽了。Flutter关注的是给你starting和stopping引擎,在大多数情况下,Flutter并不是特别需要观察Activity的生命周期。如果你无论如何都需要观察生命周期来获取或者释放Native资源,那你可能需要在Native端做这件事。 这有一个如何监听Activity的生命周期的状态的例子:

import 'package:flutter/widgets.dart';

class LifecycleWatcher extends StatefulWidget {
  
  _LifecycleWatcherState createState() => new _LifecycleWatcherState();
}

class _LifecycleWatcherState extends State<LifecycleWatcher> with WidgetsBindingObserver {
  AppLifecycleState _lastLifecyleState;

  
  void initState() {
    super.initState();
    WidgetsBinding.instance.addObserver(this);
  }

  
  void dispose() {
    WidgetsBinding.instance.removeObserver(this);
    super.dispose();
  }

  
  void didChangeAppLifecycleState(AppLifecycleState state) {
    setState(() {
      _lastLifecyleState = state;
    });
  }

  
  Widget build(BuildContext context) {
    if (_lastLifecyleState == null)
      return new Text('This widget has not observed any lifecycle changes.', textDirection: TextDirection.ltr);

    return new Text('The most recent lifecycle state this widget observed was: $_lastLifecyleState.',
        textDirection: TextDirection.ltr);
  }
}

void main() {
  runApp(new Center(child: new LifecycleWatcher()));
}